jjzjj

Goroutine 在 Windows 和 Linux 上的行为不同

全部标签

ruby - 为什么我会看到这两个几乎相同的 Ruby 正则表达式模式的不同结果,为什么一个匹配我认为不应该匹配的内容?

使用Ruby1.9.2,我在IRB中有以下Ruby代码:>r1=/^(?=.*[\d])(?=.*[\W]).{8,20}$/i>r2=/^(?=.*\d)(?=.*\W).{8,20}$/i>a=["password","1password","password1","pass1word","password1"]>a.each{|p|puts"r1:#{r1.match(p)?"+":"-"}\"#{p}\"".ljust(25)+"r2:#{r2.match(p)?"+":"-"}\"#{p}\""}这会产生以下输出:r1:-"password"r2:-"password"r1:

ruby - 尝试在 Windows 8 (x64) : Error installing fast-stemmer-1. 0.2.gem 上安装 Jekyll

我正在尝试使用本手册让Jekyll在Windows8x64上运行:RunningJekyllonWindows我正在使用来自rubyinstaller.org的以下两个下载:ruby2.0.0-p0(x64)DevKit-mingw64-64-4.7.2-20130224-1432-sfx.exe所以我根据手册设置了Ruby和DevKit(希望它是更新的版本)。我尝试运行一点HelloWorld.rb脚本,它工作正常,路径变量已设置。然后我尝试运行geminstalljekyll并得到以下输出:geminstalljekyll-outputonpastebin.com问题似乎出在名为f

ruby - 打包的 Ruby 字符串中的奇怪行为

我对某些ruby​​行为感到困惑。看下面的代码:[127].pack("C")=="\x7f"#=>true这是有道理的。现在:[128].pack("C")#=>"\x80""\x80"#=>"\x80"[128].pack("C")=="\x80"#=>falsepackoption"C"代表8-bitunsigned(unsignedchar),应该可以存储128的值。两个字符串也打印相同的东西,那么为什么它们不相等呢?这与编码有关吗?我使用的是ruby​​2.0.0p247。 最佳答案 这是错误的,因为编码不同:[128].

ruby - 通过 ruby​​2.0.0 在 Windows 上安装 iconv 时出错

在Windows上通过ruby​​2.0.0安装iconv时出错通过ruby​​2.0.0在Windows上安装iconv时出错我正在尝试安装iconv,但是当我运行以下命令时:geminstalliconv我的结果:TemporarilyenhancingPathtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...Error:Errorinstallingiconv:ERROR:Failedtobuildgemnativeextension.C:/Ruby/Ruby200/bin/ruby.exe-r./s

ruby-on-rails - 在 Windows 7 64 位上运行 gem 安装时出错

我刚刚使用ruby​​installer.org的安装程序安装了ruby​​1.9.2-p136,现在我正在尝试安装rails。当我执行“geminstallrails”时,出现以下错误:C:\Users\Clayton.USA>geminstallrailsERROR:Whileexecutinggem...(Errno::EINVAL)Invalidargument-P:/这是我正在运行的ruby​​和gem版本:C:\Users\Clayton.USA>ruby-vruby1.9.2p136(2010-12-25)[i386-mingw32]C:\Users\Clayton.US

ruby-on-rails - Windows 7 上的 Pik 不记得选择

我在Windows7上使用pik。我无法让pik记住ruby​​版本选择。例子:命令窗口1>piklist*187:ruby1.8.7(2011-02-18patchlevel334)[i386-mingw32]192:ruby1.9.2p290(2011-07-09)[i386-mingw32]193:ruby1.9.3p125(2012-02-16)[i386-mingw32]我选择版本193。>pik193>piklist187:ruby1.8.7(2011-02-18patchlevel334)[i386-mingw32]192:ruby1.9.2p290(2011-07-09

ruby-on-rails - 在 Windows 7 x64 上安装 Ruby and Rails 和 DevKit 时出现问题 - 需要修复

我在尝试安装ruby​​和rails时遇到了很多问题。在清除以前安装的版本之后,我已经尝试过没有和现在。尝试运行“geminstallrdiscount--platform=ruby”时出现以下错误:C:\Windows\system32>geminstallrdiscount--platform=rubyTemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingrdiscount:ERROR:Failedtobuildgem

ruby - Lambda 行为

我很难理解是什么使以下行为成为可能(摘自ruby镐书):defpower_proc_generatorvalue=1lambda{value+=value}endpower_proc=power_proc_generator3.times{putspower_proc.call}#=>2,4,83.times{putspower_proc_generator.call()}#=>2,2,2我没有看到“power_proc”对象如何允许值继续加倍,因为我假设(似乎是错误的)每次调用都会将值重新分配给1。我的问题是为什么“3.times{putspower_proc.call}”的结果是“

ruby-on-rails - ruby 中相同对象值的不同哈希值

我对ruby​​的“散列”方法有疑问:http://apidock.com/ruby/v1_8_7_330/Hash/hash我用它来比较具有相同内容的两个不同对象,以发现数据库对象和具有相同属性的新元素之间的冲突。它显然已经工作了很长时间(超过一年),但突然在我的开发计算机上停止工作了。如果我在Rails控制台中尝试这样做:a={:a=>'a',:b=>'b'}b={:a=>'a',:b=>'b'}a.hashb.hash我在同一控制台中为a.hash和b.hash(-3820017043059270405)获得了相同的值。问题是,如果我换到另一个控制台,它会返回与第一个控制台不同的

ruby - stub 实例方法在使用 minitest 的第二次调用时返回值不同

我正在对用户的提要进行分页,并想模拟我正在使用的API的响应。API可以返回奇怪的结果,所以我想确保如果API返回我已经看到的项目,请停止分页。我使用minitest在第一次调用方法get_next_page时stub,但我想在第二次和第三次用不同的值调用它时stub。我应该只使用rSpec吗?ruby新手...这是片段test"crawlerdoesnotpaginateifnonewitemsinnextpage"do#1:A,B#2:B,D=>D#3:A=>stopcrawler=CrawlJob.newfirst_page=[{"id"=>"item-A"},{"id"=>"i